/*
 * Copyright 2018 JDCLOUD.COM
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *    http:#www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 *
 * 云硬盘相关接口
 * 云硬盘相关接口，提供批量创建云硬盘，查询云硬盘，删除云硬盘，对云硬盘进行扩容，修改云硬盘信息以及使用快照恢复云硬盘等功能。
 *
 * OpenAPI spec version: v1
 * Contact: 
 *
 * NOTE: This class is auto generated by the jdcloud code generator program.
 */


using System;
using System.Collections.Generic;
using System.Text;
using JDCloudSDK.Core.Service;

using JDCloudSDK.Disk.Model;
using JDCloudSDK.Core.Annotation;
using Newtonsoft.Json;

namespace  JDCloudSDK.Disk.Apis
{

    /// <summary>
    ///  -   创建一块或多块按配置或者按使用时长付费的云硬盘。
        ///         /// -   云硬盘类型包括高效云盘(premium-hdd)、SSD云盘(ssd)、通用型SSD(ssd.gp1)、性能型SSD(ssd.io1)、容量型HDD(hdd.std1)。
        ///         /// -   计费方式默认为按配置付费。
        ///         /// -   创建完成后，云硬盘状态为 available。
        ///         /// -   可选参数快照 ID用于从快照创建新盘。
        ///         /// -   批量创建时，云硬盘的命名为 硬盘名称-数字，例如 myDisk-1，myDisk-2。
        ///         /// -   maxCount为最大努力，不保证一定能达到maxCount。
        ///         /// -   userTags 为创建云盘时打的标签
        ///         /// 
    /// </summary>
    public class CreateDisksRequest : JdcloudRequest
    {
        ///<summary>
        /// 创建云硬盘规格
        ///Required:true
        ///</summary>
        [Required]
        public   DiskSpec DiskSpec{ get; set; }
        ///<summary>
        /// 购买实例数量；取值范围：[1,100]
        ///Required:true
        ///</summary>
        [Required]
        public   int MaxCount{ get; set; }
        ///<summary>
        /// 用户标签,默认为空;tag标签的限制：每个资源最多允许绑定 10 个不同的标签，同一资源每个标签“键”上只能存在1个标签“值”；标签键/值只支持中文、数字、大小写字母、空格及特殊符号_.:/&#x3D;+-@;当无tags时,reps结果返回中tagmsg为空
        ///</summary>
        public List<Tag> UserTags{ get; set; }

        ///<summary>
        /// 幂等性校验参数
        ///Required:true
        ///</summary>
        [Required]
        public   string ClientToken{ get; set; }
        ///<summary>
        /// 地域ID
        ///Required:true
        ///</summary>
        [Required]
        [JsonProperty("regionId")]
        public   string RegionIdValue{ get; set; }
    }
}